I am hoping that version 1.2 will have simple actions, that will be instigated when e.g. all goals in a list become answered.
In addition, a number of other changes have been made that affect ordinary use by the knowledge engineer as well as as a server, the most visible first:
Text Fragment
. You can
also produce documents from all fragments whose attributes are False or
Unknown rather than True. The Documents Panel has
been changed accordingly. Also, so allow server to send a document, I had
to alter the generation a bit so that it did not require the document to be
currently displayed on an easel to export HTML (a minor oversight in
previous versions).
Wait()
with AmiTCP's
select()
using WaitSelect()
, but that required
repackaging ua.c and uaw.c files.
# Fixed a bug introduced into version 1.09, in which item instances were not linked to their boxgroups.
# All known Enforcer Hits has been removed. Four were found: a read of location 0 when bringing up file requester for first time, a read of location 0 when the main easel of a KB was being displayed, and a couple which wrote to locations 0x20, 0x28 when creating a new KB.
# Document easelpiece now extends almost across whole window.
# Document easel now activated on being shown.
# Fixed the bug that made slider digits switch to same font as question text.
# You can now set the Show button on attributes in item types, and then when you create an item instance of that type, those attributes whose values can be shown (bayesian, boolean, etc.) will be created with value lines. However, a slight bug: these lines do not appear visibly until the boxgroup is redrawn, such as by moving it a fraction. (Up to version 1.09 you could not switch on the Show button; if you did errors occurred.)
# Reduced vertical spacing of form gadgets to allow more per form.
# Documents: Making up a document is now becoming simpler. Has own panel, complete with ability to export it. The facility is still rather limited, and so is not within the main documentation; it is to be found in a separate page.
# Preferences. Before, altering the fonts for questions had no direct effect on font actually used; now does. Also, altering font for document was ok - until you zoomed it, then font reverted to main easel font. Now OK.
# Exporting the main easel is now done via the Easel panel.
# Questions asked of user are now logged. At present, the log file is ram:QnLog, which is rather inflexible and you have to copy that file to disk if you wish to retain it. Reason for ram: is because we don't want to keep a disk file open for lengthy periods.
# Also, question text now in black rather than white, to enhance readability.
# A User Texts facility has been introduced which extends the range of user texts available. This is accessible either from the Attribute Details Panel via the 'User Texts' button, or from the User Question panel via the Att button. We now have multiple help texts and also a separate Form text, which gives a short text for use on forms.
# Multiple Help Texts. The main change is that you can give up to 8 different Help texts, labelled on the User Question Panel 'Help' and '1' to '7'. These can be used for different kinds of Help, such as 'What does this question mean?', 'What is the implication of answering this in certain ways?', 'What if I say 'unknown'?' and so on. You can use them as you wish - only, remember to tell your users.
# (An internal change that you should know about.) New SysAtt Identifier for the main Help text. If you have an attribute with help text entered under a KB earlier than 1.087, then it will NOT show up when the user presses Help. But, from version 1.0872, you can copy it to the new help identifier (that does show up) by entering the User Texts Panel, and using the Temporary 'T' Text and the T Buttons. You will find the old help text is the Temporary Text. (Version 1.0871 did not have this concept of temporary text, and the only way you could make use of the old text was to reply Yes to a special question of whether to convert it to new help or not.)
# Topics: Now have three columns and up to 30 shown.
# The Meaning Bar is no longer obscured by large panels, as it was (with Attribute Details, Relationship Instance Details, Preferences, Postscript parameters, user question value, user form, help screen, etc. (Some smaller ones still place themselves over it, but you can move them.)
# Question text length. Was restricted to 256 chars; updated now to 512. I've also confined the question box so it does not mess up the value gadget.
# Attribute action panel has been made a little safer. Not only has the crash been fixed, but it will not allow you to run up two parallel inference sessions with the same attribute! It warns you so.
# Bugfix: During an inference session with a goal list, if user hit 'ResetQ', then only those questions asked during the current goal in the goal list were shown. This has now been fixed, so that all questions of the session are shown.
# Bugfix: Chooser. If first ante was boolean then Istar would not backward chain up the correct one, and would report being unable to answer the attribute. This has now been fixed; see next point.
# Activity of Chooser has been extended beyond integers and booleans in the first ante. If the first ante is boolean or some other truth-valued attribute then if false it will take the next (2nd) ante and if true the 3rd. (Truth-valued att = boolean, bayesian, probability and odds.) If not a truth-valued att, then it tries to convert it to integer and takes it as an integer.
# Bugfix: Used to Crash when you remove Attribute Action Panel during an inference run. Now, during an inference run or overriding you cannot remove the panel.
# Bugfix: If you had an ORDINAL or ENUM antecedent e.g. Weekdays and tried to set the unary operator to EqualTo, then it would not do so. Now it does. (The bug only affected ORDINALs and ENUMs.) A reason for doing this is to convert an enum to a boolean saying e.g. 'It is Wednesday'.
# When you set the archive flag in the KBInfo panel, so it renames the original file on saving, the name the archive received was a clumsy datestamp. I replaced this with a TimesSaved number. Shorter and nicer.
# Bugfixes: Inferencing FirstKnown did not allow CONTROL unary operator to work. Also, string concatenation and chooser did not work. Also, HowManyIsIn inference did not work for strings. These have been fixed.
# Ordinal can now be converted to Proportion, Probability and (the probability part of) Bayesian as long as it has a Limit that is non-zero. The result is (OrdVal - 1)/(Limit - 1). The reverse cannot work, however.
There has been quite a lot of work on inference and unary operators in particular, to give the following changes.
The relationship explanation facility has not been made more accurate, hopefully now addressing the whole range of possibilities.
Added unary operators of EqualTo, GreaterThan, etc. which returns a boolean result of how the ante value compares with the one on the weight.
Now CONTROL type links are not restricted to Boolean antecedents, but can take anything that can convert to a BOOL, namely Probability, Bayesian and Odds.
In bayesian inference, if you have an Odds antecedent, then it will be used directly as the odds multiplier; in this way you can exercise direct control over bayesian mechanism if you wish. This gives slightly different behaviour from previous versions, in the rare occasions in which Odds antecedents were used for bayesian inference.
You can now have the ProbAnd and ProbOr unary operators on links for which the antecedent is Boolean, in which case the link weight is a Probability (or Proportion) and this type is used in the inference. With ProbAnd, if the ante is true, then the value used in inference is a probability equal to the link weight, but if the ante is false then the value used is 0. With ProbOr, the link weight is applied if the ante is false, and if true the value used is unity.
The bug in which the NEGATE unary operator did not work for booleans and probabilities involved in bayesian accumulation, now works. In fact, for bayesian inference, NEGATE and INVERT are the same.
The Relationship Instance Panel now puts up the correct type of gadget for the weight - but if you change unary operator then you must 'OK' and bring it up again to get the new gadget type.
Fixed a rare crash: if you tried to save an easel as IFF and did not have iff.library in libs: then it would crash - fixed.
The Attribute Action Panel now activates the main easel once inferencing has completed. It was a nuisance that it did not before.
I've also added a couple of things that enhance Istar's usability when creating KBs:
I removed the Undo button from the User Question Panel since it didn't work properly and was not really needed; hit the newly-labelled ResetQ button instead (was 'Review').
Since the last version, which never got put out properly, I diverted work to the Annotator, which allows historians, space scientists etc. to annotate digitized pictures and form a database of their contents for analysis. Much of the same software base is used, but in a slightly different way, with more emphasis on standard items of a semantic net form, and less of free attributes. A lot of things were changed and made more flexible, and I have taken some of them back across to Istar.
VERSION Istar
and it should say: Istar 1.08 Jan 3
1998
. If it gives an earlier date, download the new version.
Lists are ordered sets of things in the knowledge base, and you can use them for various purposes, and in future even more purposes. They are created via the Lists Panel, which is brought up when you hit the Lists button on the KB Panel. Database-aware people will see they are like 'relations' in a relational database, that are produced as a result of a relational operation. (NOTE: In that sentence 'relation' has almost *nothing* to do with relationship! It is a jargon term of the database community.) The purposes for which you might use a List include:
Lists are formed via the Lists Panel, in a two-step operation which is shown on the panel as two long cycle buttons, the width of the panel, and various detail gadgets below them:
To operate a Volunteer or Override List, select it as current goal list and hit ResetGoals and InferGoals.
On the Attribute Details, Item Details and Relationship Instance panels you will find a new line of gadgets giving pens and pattern and, maybe, size. Also DSAP of the EaselPiece concerned. (Note: In the Item Details Panel, the pens are for the item's own box, which might not be displayed. These will NOT affect the colour of the attribute box of a free attribute.)
You can also now change the sizes, which are in 1/256ths of an inch as on a 14 inch screen (or tenths of a millimetre to within 1%). Also on the ItemType and Relationship Type and Attribute Type Panels.
The reason behind this is to get ready for obtaining information across the internet. When this happens you want to post a request for the information, but not have to wait for its arrival.
Many panel lists, especially of types, attributes and related things, have been standardised and made more flexible. In general, each list now comes with a set of small buttons surrounding it, to allow the moving of things up and down the list, going to see the selected thing in the list, getting rid of a thing in the list, and creating a new thing in the list. In some lists some buttons are missing for e.g. safety reasons.
This provides extra flexibility. For instance, you can now re-order the item and relationship types if you wish, and also the attributes of an item.
What this means is that some instances of a given type might have extra attributes (and some have less). This can be useful when you might have e.g. sub-types emerging during your analysis.
When you hit the See button an Attribute Type (singular) Panel comes up, which has name, meaning, visual appearance gadgets as above, and list of value names for ENUMs and ORDINALs.
To create a new attribute type, a small panel comes up, showing steps the user must go through - give it a value type, give it a name and a meaning. Then the Attribute Type Panel appears (sometimes) for you to enter more details.
# Goal Lists. In previous versions you had precisely one goal list. Now you can make up any number of goal lists, using the lists facility above, so that, for instance, you can have a main goal list plus several override lists on which you can do common what-if queries.
# Better file handling. With previous versions when you asked for an ascii dump of a KB, the default file to which it would output the ascii was the KB file itself !!. Danger of losing all your work! Problem was that there was only one file requester allocated for all file output. I've now got different requesters for:
# VGA screens. Previous versions of Istar gave a PAL screen regardless of Workbench. Now its screen mode is that of WorkBench. (However, in VGA mode some of the control screen panels are a bit odd-sized; this will be fixed soon.)
# Keys. First, you can now show the consequent fan/net as well as the antecedent one. Press 'C' over a box for the consequent and 'A' for antecedent.
# Keys. Second, it will now show all kinds of relationship in the antecedent and consequent fans, not just inference.
# Keys. Third, I've changed the keys used. For two reasons. One is that when used on a CD32 with SX32 keyboard there are no keys around the numeric keypad and the other is that I could never remember which keys were used. So I now use alphabetic keys that bear some resemblance to the action needed:
# Minimize/Maximize box size. A new facility. Some boxes are of little intrinsic meaning, merely being minor variants on the meaning of others. Often you get a local bunch of antecedents that merely set the value for a more important box. So now you can minimize these less important boxes by hitting the 'M' key when the mouse is over them. This turns them into little squares, quarter of an inch square and with not label - a bunch of these starts to look like a bunch of blackcurrants. Their meaning still shows, however, and you can do all the normal things to them. Then, if you hit 'M' again over a minimized box it expands to its normal size.
# In Attribute Details panel, if att is a Const in derivation and you alter the value then it is set to answered. And the result is propagated. Because it is assumed that you are altering it for a purpose.
# On using a large KB (ca. 800 boxes and 400 arrows) and a goal list about 100 long it took around 3 seconds to reset all the goals on a basic Amiga 1200. (Because all the consequent fans of all reset attributes have to be traversed.) A noticeable delay, though not unreasonable for a KB of this size and complexity. I investigated the time taken (3.3 seconds on basic Amiga 1200 and 1.4 seconds on Amiga 1200 with 50MHz 68030) and checked that the algorithm was working OK and not doing more work than it need to (it was OK). There might be ways of speeding it up slightly. But at present it is not high priority; 1.4 seconds delay seems perfectly reasonably for a KB this size when the subsequent question sequence is around 40 questions long.
# Bug in Chooser was fixed. It now resets attribute to unanswered every time.
# Wee Bugfix. When you added an attribute to an item that had an att with shown value it didnae do it right - placing the 2nd on top of the first. It now does it right.
# Instituted an initial dynamic document facility. You create Document items and the document is created dynamically from 'Text Item' items whose 'Include' attributes are true. See Item Details Panel. The facility is at present very crude, just so you can start to try it out. See the new 'Dynamic Documents' file.
# Found bug that stopped Istar being used on the 4000 and 3000 - and corrected it.
# You can now add new attributes to existing item instances (you could add to item types before, but not instances). e.g. if the standard 'Cat' item type has attributes of Name, Has-Whiskers, Colour and Sound-Made, and you make instance 'Susie', with attributes: Has-Whiskers = TRUE, Colour = Grey, Sound-Made = Miaow, before, that was all you could record about Susie. But now you can add any new attributes you like without affecting the item type. So you can enter Number-Of-Legs = 3 (she got run over!).
# You can also re-order attributes now in both item types and item instances.
# You can now read and write preferences files.
# I went through all the modules with a fine tooth comb, making some internal changes (specifically, replacing rbDataAddr() with ikDataAddr(), etc.). In particular, some of the old code made the wrong tests after a routine returns a C pointer. Took the opportunity to rationalize the error handling and error messages.
# Found a bug had crept into Version 1.04 that prevented changing value types in Attributes Details panel. So corrected it.
# Also, internal changes to the way text of labels is displayed.
# Lots of work allowing you to set Preferences ...
# Will now read IstarSys:IstarPrefs, if available, when starting up to set various preferences. An IstarPrefs_LowMem is supplied.
# Can now change fonts for the main easel, the user questions and the document. (Note: document facility still not available.)
# The Preferences panel now has KB and font information as well as Easel info, and it only sets the sizes for new KBs, not the existing one. (Scroll amount is set for all KBs and Easels, though.) This makes it easier to prepare for a low memory situation.
# Added facility to switch tracing on in the command line.
# Changing the size of a currently displayed Easel is now done from a new 'Easel' button on the KB Panel, not from the Preferences panel.
# A wee change: Before, on hitting 'Quit' it would first ask "Do you want to quit?" and then ask for each KB "Do you want to get rid of it?" Now it asks about all the KBs first, and then "Quit?" This allows you to clear out all the KBs but not quit the program, so to start other KBs again.
# A button on KB panel 'See Easel' will bring the easel of that KB to the front; useful when you have several KBs up.
# Tidied up all panel handling. Users shouldn't see any difference, but it makes a bit smaller.
# New documentation file, KBs, which outlines all manipulation of whole knowledge bases, and IstarPrefs file.
# Resizing of a KB is now possible, but occasionally fragile; see Bugs and Limitations.
# When saving a KB you can now have automatic backups made of the file: see KBs document. The old file is not overwritten, but has date and time appended to it.
# Slight improvements to the Explanation of Relationship Instances.
# Added facility to alter the visual appearance of item boxes, in a limited way. Pen 1 gives the text colour for the label, Pen 2 and Pattern give the appearance of the box outline. This meant new gadgets added to the Item Type Panel.
# Added facility to define, for an item type box, which types of relationship will be drawn when user starts drawing from left or right edge.
# Added KB Area panel, showing some details of the KB area, and allowing you to alter some.
# Tidied up the mechanism for handling several KBs. Removed one or two bugs that had crept in, such as referring to certain things in KB1 when KB2 was active.
# Added facility to record the Control Screen Parking position.
# Hopefully more tolerant when it doesn't find the fonts it wants.
# Cured one or two bugs encountered when linking items or moving links.
# Tidied up Preferences (but still too few), and cured the problems that happened when setting them without a KB.
# Removed the crash/inf loop when hitting the meaning-bar right hand gadgets when there is no KB. (As I never told users about them, this should not have been a problem.)
# Istar will now process more than one KB.
# It meant replacing the separate Select Item Type, Select Relationship Type and Goal List panels with a single single KB panel. Each knowledge base has its own KB panel.
# It also meant some internal changes to the structure of the modules management, ES module operations, and other things, which are not described here. (They are described in my Logs.)
# I also put the backward and forward chaining on a sounder footing. Normally it worked OK but some funnies happened with overridden attributes.
# When resetting an attribute for backward chaining, all its antecedents were reset OK, but the other consequents of those were not reset. Now they are.
# Implemented facility to define new relationship types. This enables us to move towards a semantic net builder.
# Added RANDOM unary operator.
# Proper implementation of limits on ordinals and enums.